Skip to content

Conversation

@RunDevelopment
Copy link
Contributor

@RunDevelopment RunDevelopment commented May 1, 2025

Resolves #2435
Resolves #2093

In this PR, I removed the old DDS decoder implementation and added a new decoder and encoder based on the dds crate.

Decoder: The decoder now supports a bunch more formats, cube maps, rectangle decoding, and the ability to decode as a color format of the user's choosing.

Encoder: The encoder supports a selection of DDS formats, automatic mipmap generation, dithering, compression quality, and both header formats. If the user does specify a format, the encoder will automatically pick an uncompressed that can losslessly represent the image.
Only encoding single images (with optional mipmaps) is supported. Cube maps, texture arrays, and volumes are not. They could be in the future, but I don't see the need right now.

Changes:

  • Add dds as a (private) dependency.
  • Use dds to power a new DDS de/encoder API for image. I made all new types, so nothing from dds is re-exported/used publicly.
  • Removed old DXT implementation. This was already non-public, so I don't think this will cause any issues.

TODO:

  • Add more documentation. The DdsDecoder and DdsEncoder structs should have a lengthy doc comment explaining what they can do and how they are supposed to be used.
  • Add tests.

@RunDevelopment RunDevelopment changed the title Dds New DDS decoder and encoder May 1, 2025
@RunDevelopment RunDevelopment mentioned this pull request May 1, 2025
@RunDevelopment
Copy link
Contributor Author

I fixed the error for test_toolchains (1.70.0) in image-rs/image-dds#59, so just cargo-deny remains. It doesn't like that dds uses a newer version of zerocopy than some other dependency. I'm not sure what the best solution for that is. Should I downgrade the version to v0.7.x, or should I try to make dds work with both v0.8.x and v0.7.x? dds doesn't use a lot of zerocopy's APIs, so this might be possible.

@RunDevelopment
Copy link
Contributor Author

Nice, cargo-deny solved itself. I haven't looked into it, but I think the other dep got updated and now uses zerocopy v0.8.x.

@nickbabcock
Copy link

I tested this branch and am very pleased. The current dds decoder is very limiting and confusing (returning errors like "The image format DDS is not supported") that it should be called out in the docs. This branch fixed all those issues.

Excited to see this land.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

None yet

Projects

None yet

Development

Successfully merging this pull request may close these issues.

DDS support Encoding DDS images?

2 participants